﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using FlorDeLiz.BusinessEntitites;
using FlorDeLiz.DataAccess;
using FlorDeLiz.LogException;
using System.Reflection;

namespace FlorDeLiz.BusinessLayer
{
    public class ProdutoBL
    {
        #region Singleton
        private static ProdutoBL instancia;
        public static ProdutoBL Instancia
        {
            get
            {
                if (instancia == null)
                {
                    instancia = new ProdutoBL();
                }
                return instancia;
            }
        }
        #endregion

        public List<Produto> ObterProdutos(int? id, string codigo, string nome, string descricao)
        {
            try
            {
                return ProdutoDA.Instancia.ObterProdutos(id, codigo, nome, descricao);
            }
            catch (Exception ex)
            {
                LogService.GravarLog(Log.Instancia.Loggin(DateTime.Now,
                                             ex.Message,
                                             MethodBase.GetCurrentMethod().DeclaringType.Name,
                                             MethodBase.GetCurrentMethod().Name,
                                             ex.StackTrace));
                return null;
            }
        }

        public Produto GravarProduto(Produto produto)
        {
            try
            {
                if (produto.Id == 0)
                {
                    produto = ProdutoDA.Instancia.InserirProduto(produto);
                }
                else
                {
                    produto = ProdutoDA.Instancia.AlterarProduto(produto);
                }
                return produto;
            }
            catch (Exception ex)
            {
                LogService.GravarLog(Log.Instancia.Loggin(DateTime.Now,
                                             ex.Message,
                                             MethodBase.GetCurrentMethod().DeclaringType.Name,
                                             MethodBase.GetCurrentMethod().Name,
                                             ex.StackTrace));
                produto.OcorreuErro = true;
                produto.Mensagem = "Falha ao Gravar Produto!";
                return produto;
            }
        }

    }
}
